<template>
  <!-- element-ui级联组件 -->
  <el-cascader
    placeholder="请选择"
    size="mini"
    :options="departmentList"
    :props="props"
    separator="-"
    :value="value"
    @change="changeValue"
  />
</template>

<script>
import { getDepartmentAPI } from '@/api/department'
import { list2Tree } from '@/utils'
export default {
  props: {
    value: {
      type: Number, // 存储的是部门的id  3 4 5
      default: null
    }
  },
  data() {
    return {
      // 部门列表
      departmentList: [],
      props: {
        label: 'name', // 部门名称
        value: 'id'
        // 部门id
      }
    }
  },
  // 最先发请求
  async created() {
    const res = await getDepartmentAPI()
    this.departmentList = list2Tree(res, 0)
  },
  methods: {
    changeValue(list) {
      // 取到数组的最后一次
      if (list.length) {
        this.$emit('input', list[list.length - 1]) // 将最后一位的id取出来 传出去
      } else {
        this.$emit('input', null) // 如果长度为0 说明值为空
      }
    }
  }
}
</script>

<style>

</style>
